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(54) Method for the distribution of a real-time multi-client service 



(57) The invention relates to the determination of 
service suppliers for the distribution of a service within 
a network. The invented method enables the selection 
of service suppliers according to a user defined policy. 
In the method the requirements for the service are de- 



termined, the characteristics of service suppliers and cli- 
ents are determined, for each client the service suppli- 
ers are determined that can support the client, from 
these service suppliers a set of service suppliers is de- 
termined that can supply the service to all clients and 
finally for each client one service supplier is selected. 
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Description 

Field of Invention 

[0001] The Invention relates to a method for distribut- 
ing a service within a network. 
[0002] For example real-time services put strong de- 
mands on the maximum processing time, If a real time 
service is used by a plurality of clients the requirements 
regarding processing capacity often can be met by using 
a plurality of service suppliers, providing said service to 
the clients. A plurality of service suppliers can be imple- 
mented by using a computer network, that is an inter- 
connected collection of autonomous computers. 

Description of prior art 

[0003] Computer networks have the disadvantage, 
that they require certain knowledge from a user regard- 
ing for example the topology. 

Due to the development of powerful microprocessors 
and high-speed computer networks, it has become fea- 
sible to set up distributed systems and put together com- 
puting systems composed of large numbers of CPUs 
connected by a high-speed network. 
A distributed system is different from a computer net- 
work in that it provides some form of networking trans- 
parency such as access, location, replication and distri- 
bution transparency to the user. The user of a distributed 
system does not need to be aware of the multiple, pos- 
sibly heterogeneous, processing platforms that are of- 
ten placed at different locations. In effect, a distributed 
system is a software system built on top of a network. 
The software gives It a high degree of coheslveness and 
transparency. Thus the distinction between a network 
and a distributed system lies with the software, espe- 
cially the operating system, rather than with the hard- 
ware. Andrew S. Tanenbaum describes distributed sys- 
tems in Distributed operating systems, second edition, 
published in 1995. 

[0004] It is a problem to determine an optimised dis- 
tribution of a service that is which service suppliers are 
selected for the provision of a service to a plurality of 
clients, within a network. 

Summary of the invention 

[0005] This problem Is solved advantageously by the 
method of claim 1 and the computer program of claim 
12. 

[0006] Further advantageous embodiments can be 
derived from the dependent claims 2 to 11 . 
[0007] Advantageous is the generation of a service 
distribution tree according to claim 2. This allows the re- 
duction of the distribution problem to a problem that is 
much less complex. 

[0008] Further advantageous is the use of a simplified 
service distribution tree according to claim 3. By using 



a simplified service distribution tree it becomes obvious 
how to select service suppliers according to require- 
ments. 

[0009] Especially advantageous is the choice be- 
5 tween migration, replication, and partitioning of a serv- 
ice according to claim 4. This enables an operator to 
react more flexible on requirements on the distribution. 
[0010] Further advantageous is the use of a prede- 
fined policy for the selection of service suppliers accord- 
ing to claim 5. This enables a consistence choice of 
service suppliers taking preferences into account. 
[0011] Further advantageous is the determination of 
delays among service suppliers and of the maximum de- 
lay permitted according to claim 6. By this it is avoided 
that a distribution is selected that does not fulfil the re- 
quirements regarding delays. 
[001 2] Especially advantageous is the use of a central 
updating unit and the determination of delays between 
said updating unit and the service suppliers according 
to claim 7. A central updating unit is a simple way to 
guarantee consistent data and it reduces the complexity 
of the delay problem. 

[0013] Further advantageous is the use of different 
service suppliers for the uplink and downlink connection 
according to claim 8. By this asymmetrical data amounts 
can be taken Into account for the distribution of a serv- 
ice. 

[0014] It is object of the invention to provide a method 
for determining a distribution of a service in a network. 
[0015] A service can be distributed in three ways, by 
partitioning, by replication, and by migration. 
[0016] A service or resource is partitioned when mul- 
tiple service suppliers provide it, each of the service sup- 
pliers capable of handling a subset of the requests for 
service. Each request can be handled by one of the 
service suppliers implementing the service. A partition- 
ing function maps requests to the subset of the nodes 
that can handle it. Communication between the different 
partitions may be needed to inform each other about up- 
dates. 

[0017] A service or resource is replicated when it has 
multiple logically identical instances appearing on differ- 
ent service suppliers in a system. A request for access 
to the service can be directed to any of its instances. 
Several mechanisms are available to synchronise the 
different copies, also called replicas, and keep them 
consistent. Caching is seen as a special case of repli- 
cation where at least parts of the service are copied clos- 
er to the client in order to reduce network transmission 
and access times. In case of replication a different serv- 
ice access point for example an IP address is used for 
each service instance. In case of caching the same serv- 
ice access point is used by the client. Several caching 
variants have been defined. 

[0018] A service or resource is migrated when a cen- 
tral, independent service supplier takes care of all serv- 
ice requests and that service supplier transports itself 
between platforms. An example of a service migration 
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is a mobile search agent that is sent out on the network. 
There is no relation with any other search agent, unless 
several agents have got the same or parts of the order 
and copies and overlaps should be filtered out etc. In 
that case replication or distribution would apply. 
[001 9J A service can be distributed in either way or by 
using a combination of them. 

A service supplier can be for example a server, a proxy 
server, a sub-network like an intermediate network or 
an access network, or a network node. 
[0020] A client is for example a user equipment, a mo- 
bile user equipment, a telecommunication device, an 
access network, or a personal computer. 
[0021] An access network comprises at least one 
node, providing access for a client to telecommunication 
network. An example for an access networks Is UTRAN 
(UMTS Terrestrial Radio Access Network), 
[0022] An intermediate network is a network that con- 
nects an access network to a core network. Examples 
for intermediate networks are Internet based networks 
or trunk networks. 

[0023] A core network provides telecommunication 
services and functionality to a user or client. Such serv- 
ices are for example telephony, data transmission, 
switching functions, and handling of users. 
[0024] A service supplier has to meet certain require- 
ments for the provision of the service to at least one cli- 
ent. The service, a client, the service provider or a net- 
work operator for example can define such require- 
ments. The requirements are software requirements, 
hardware requirements or requirements on the commu- 
nication for example among service suppliers or be- 
tween a service supplier and a client. Examples for soft- 
ware requirements are for example an operating system 
or certain software products that are necessary to run 
the service. Hardware requirements are for example 
memory space or performance. Requirements regard- 
ing communication are for example jitter, bandwidth, se- 
curity, reliability and delay. Security is the protection 
against unauthorised reading and modification of data. 
Reliability is the protection against erroneous data. The 
capabilities of a client or a service supplier to fulfil the 
requirements are called characteristics. 

Brief description of the drawings 

[0025] The following figures show: 

Fig. 1 : depicts a distributed system as state of the art, 
Fig. 2: depicts a distributed system structured by a 

service distribution tree, 
Fig. 3: depicts a distributed system structured by 
service distribution tree with a schematic 
which service supplier can support which cli- 
ent, 

Fig. 4: depicts a simplified service distribution tree, 
and 

Fig. 5: depicts a table for the selection of service sup- 



pliers. 

Detailed description of embodiments 

5 [0026] In the following the invention is described in 
more detail by means of embodiments and figures. 
Equal reference signs indicate equal elements. Not 
shown in the figures Is the connection between the serv- 
er Serv and the service supplier S 1 . The inventive meth- 
10 od is described by the example of a service that is rep- 
licated but is not restricted to that. The mechanisms de- 
scribed below work for all three ways of distribution. 
[0027] Figure 1 depicts a distributed system, compris- 
ing a server Serv, a plurality of service suppliers S1 , S2, 
15 S3, S4, S5, S6, S7, S8, S9, S10, S11, S12, S13, S14, 
S15, S16, S17, S1B, S19, S20, S21 ; S22, S33 and the 
clients C1 and C2. The service supplier in a first domain 
D1 can provide the service to the client C1 ; the service 
supplier in the second domain D2 can provide the serv- 
ice to the client C2. The other service suppliers are not 
capable of providing the service for example because 
the delay is too high. The service suppliers form a net- 
work NW1 . It is also possible to regard the server Serv 
and or the clients C1 to C7 as part of the network. 
[0028] In a first embodiment of the invention the re- 
quirements of a service are determined. In a preferred 
embodiment this is performed by a service transmitting 
its requirements for example as service classes. 
[0029] The characteristics of service suppliers and cli- 
ents are determined in a further step. In a preferred em- 
bodiment bandwidth brokers serving domains perform 
this. The bandwidth brokers collect information about 
the characteristics of service suppliers and clients within 
their domain. 

[0030] In a further step it is determined for each client, 
which service suppliers can provide the service to it. In 
a preferred embodiment, the clients perform said deter- 
mination. 

[0031] A set of service suppliers is determined in a 
further step. The set of service suppliers comprises for 
each client at least one service supplier that is capable 
of providing a service to the client. It is object of the in- 
vention, to determine as few service suppliers as pos- 
sible for the set. 

[0032] In a last step, a service supplier is selected for 
each client. 

[0033] In an embodiment of the invention, a service 
distribution tree SDT1 is used to structure the service 
suppliers. 

[0034] A service distribution tree is depicted in figure 
2. It comprises all the elements of figure 1 and addition- 
ally a structure for the service suppliers and the clients 
C3, C4, C5, C6, and C7. 

[0035] For each single client a good approximation 
places service instances on the shortest path between 
the server and the client. Although this is the shortest 
path between the client and the server, it is not neces- 
sarily the shortest path from the client to each service 
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supplier on that shortest path. Considering the shortest 
path between the client and server reduces the problem 
space from a group to a line of service suppliers. 
[0036] Since the service distribution has a single 
source, the server Serv, and multiple clients C1 and C2, 
and the single client service distribution is based on 
shortest paths, the delivery tree can be created by the 
Reverse Path Multicast (RPM) algorithm. A person 
skilled In the art knows this algorithm from Hersent, Gur- 
le, and Petit, IP Telephony: Packet based multimedia 
communication systems published by Addison-Wesley 
in 2000. 

[0037] Reverse Path Multicast builds source-based 
trees that span service suppliers with clients and service 
supplier along the shortest path to service supplier with 
clients. The resulting delivery tree is also known as Sin- 
gle-Source Shortest Paths from Manber's introduction 
to Algorithms published by Addison-Wesley In 1 989. 
[0038] Other delivery trees, such as minimum cost 
spanning trees or Steiner trees can also be applied. 
[0039] The RPM distribution tree algorithm creates a 
tree of service suppliers according to a predefined met- 
ric or combination of metrics. Since there is a unique 
path from the server to each access network, loops are 
impossible. Because clients are not part of the network 
NW1 , each path from the server will end in one client. 
Thus, the clients are leafs in the service distribution tree. 
[0040] In an embodiment of the invention, different 
service trees based on different metrics like distance, 
costs, delay, and bandwidth are built for different re- 
quirements. In a further embodiment of the invention, 
service suppliers are selected if they belong to all of the 
different service distribution trees built for different met- 
rics. 

[0041] In a preferred embodiment of the invention, the 
determination of service suppliers is performed along 
the branches of a distribution tree. 
[0042] Figure 3 depicts a distribution tree with a sche- 
matic of which service supplier can support which client. 
It comprises all elements of figure 2, In addition to figure 
2, it is depicted which service supplier can support which 
client by surrounding them with a closed line. For exam- 
ple the service suppliers S2, S3, S4, S5 and S6 can sup- 
port client C1 . Client C2 can be supported by the service 
suppliers S2, S3, S7. and S8; client C3 by service sup- 
pliers S12, S13, and S14; client C4 by service suppliers 
S16, S20, and S21 ; client C5 by service suppliers S20 
and S22; client C6 by service suppliers S20 and S23 
and client C7 by the service suppliers S15, S16, S17, 
S18, andS19. 

[0043] In a preferred embodiment of the invention a 
simplified service distribution tree is used for determin- 
ing the set of service suppliers. 
[0044] Figure 4 shows an example of a simplified 
service distribution tree SSDT1 . The service distribution 
tree of figures 2 and 3 has been simplified by removing 
service suppliers that cannot serve at least two clients. 
That leaves the service suppliers S2, S3, S16 and S2Q. 



Connections that lead from one of the service suppliers 
to a client are depicted as thick lines. The other connec- 
tions are depicted as broken lines. It Is obvious from the 
simplified service distribution tree SSDT1 , that either of 

5 the service suppliers S2 and S3 can be selected for sup- 
plying the service to the clients C1 and C2. 
[0045] In a preferred embodiment of the invention, the 
selection of service suppliers for the set of service sup- 
pliers depends on a policy, defined by an operator, a 

10 service provider, a client or the service. 

[0046] In a preferred embodiment of the invention, the 
selection of service suppliers from the set of service sup- 
pliers depends on a policy, defined by an operator, a 
service provider, a client or the service. 

is [0047] Policies can define for example a preference 
of service suppliers of a certain operator, a more cen- 
tralised approach or a more distributed approach or a 
preference of a certain hardware or software. 
[0048] A centralised approach is the preference of 

20 service suppliers that are closer to the server Serv. A 
distributed approach is the preference of service suppli- 
ers that are closer to a client. 
[0049] A centralised approach has the advantage that 
updatings of data are reduced while a distributed ap- 

25 proach is advantageous if transmission time between a 
client and a service supplier is crucial. 
[0050] In a further embodiment the service suppliers 
are selected by using load-sharing mechanisms. 
[0051] In another embodiment the service suppliers 

30 are selected at random. 

[0052] Client C4 can be served by either S20 or S1 6. 
In the example S3 is selected for supplying C1 and C2 
and S20 for C4 as the policy is to select the service sup- 
plier that is closer to the client. This decreases the delay 

35 between the client and the service supplier. In general 
leads the selection of a service supplier that is close to 
the client to an improved overall service quality. 
[0053] In a further embodiment of the invention, band- 
width jitter and delay among service suppliers are de- 

40 termined before a decision is made depending on the 
result of said determination. 

[0054] In another embodiment, the maximum delay 
that is permitted among service suppliers is determined 
and compared with the result of the determination of de- 
45 lays among service suppliers. The delay between two 
service suppliers can be derived for example by the rout- 
ing protocols. The selection of service suppliers for the 
set of service suppliers depends on the result of said 
comparison. 

so [0055] In a preferred embodiment, one central update 
unit is selected. This update unit can be one of the serv- 
ice suppliers or a further device. The central update unit 
receives changes performed by clients, either from the 
clients or from service suppliers serving the clients, and 

55 updates data in the service suppliers. The delay be- 
tween the service suppliers and the central update unit 
is determined. The delay is taken into account at the se- 
lection of service suppliers for the set of service suppli- 
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ers. This can be a hard decision , for example if the delay 
between the service supplier and the central update unit 
exceeds the maximum permitted delay, or a soft deci- 
sion if certain values for the delay are preferred. 
[0056] In an embodiment of the Invention, it is distin- 
guished between an uplink and a downlink connection. 
An uplink connection Is a connection from a client to a 
service supplier; a downlink connection is a connection 
from a service supplier to a client. The downlink connec- 
tion is between a different service supplier and a client 
than the uplink connection. 

[0057] In one embodiment of the Invention, the down- 
link connection is implemented as a connection from 
one service supplier to many clients. 
[0058] A one service supplier to many clients down- 
link connection is used for example for multi-media 
streaming services. 

[0059] In a further embodiment, the uplink connection 
is implemented as a connection from many clients to 
one service supplier. 

[0060] Such many clients to one service supplier up- 
link connections are used for example in the case that 
a central update unit is used to provide data consistency. 
[0061] In an embodiment of the Invention, wherein a 
one service supplier many clients downlink connection 
is implemented, the downlink connection is used for up- 
date information, only. 

[0062] The selection of service suppliers for the set of 
service suppliers can be performed by using a table. Fig- 
ure 5 shows a table comprising all clients C1 , C2, C3, 
C4, C5, C6, and 07 and all service suppliers S1, S2, 
S23, S4, S5, S6, S7, S8, S9, S10, S11 , S12, S13, S14, 
S15, S16, S17, S18, S19, S20, S21 , S22, and S23 with 
a column per client and a row per service supplier in the 
service distribution tree. At the intersection of a row and 
a column a mark is set if the respective service supplier 
is capable of providing the service to the client. A further 
column comprises an identification of the clients a serv- 
ice supplier can support. In the rightmost column the lev- 
el of the service supplier within the service distribution 
tree Is Indicated. There are several approaches to opti- 
mise the selection of service suppliers. 
[0063] The first one is to use a top down approach. 
The top down approach starts at the highest level, level 
1 of the service distribution tree, and a service supplier 
found there, capable of serving at least two clients is 
selected. The other entries and marks of service suppli- 
ers serving the client are removed. This method is con- 
tinued in the respective next lower level until all service 
suppliers that support at least two clients are selected. 
Then it Is checked, whether all clients are supported. If 
not, the method stars again atthe highest level, this time 
selecting service suppliers supporting one of the not yet 
supported clients. After a service supplier is selected, 
all entries for the respective client are removed. This 
continues until all clients are supported. By this, each 
client is supported by the service supplier that is the 
highest one in the service distribution tree. 



[0064] Shortcomings of the top down approach are 
that it does not necessarily lead to the lowest possible 
number of service suppliers, and that it always leads to 
a more centralised distribution system. 
s [0065] A further approach is the bottom up approach. 
Apart form the direction of checks, from the lowest level 
in the distribution tree to the highest level instead of vice 
versa, It is performed equally to the top down approach. 
[0066] Shortcomings of the bottom up approach are 
10 that it does not necessarily lead to the lowest possible 
number of service suppliers, and that it always leads to 
a distributed distribution system. 
[0067] Another approach is the maximum number ap- 
proach. In the maximum number approach the service 
is supplier that can serve the highest number of clients is 
selected first. Other entries for the clients that can be 
supported by the selected service supplier are removed. 
Afterwards the service supplier that serves the second 
highest number is selected. This is continued until all 
clients are supported by a service supplier. 
[0068] This approach leads with the highest probabil- 
ity of all approaches to a minimum number of service 
suppliers, but there is no information in advance wheth- 
er service suppliers of a higher or a lower level within 
the service distribution tree are selected. 
[0069] The table as shown in figure 5 is not limited to 
the columns as shown in the figure. Further require- 
ments that are taken into account can lead to further col- 
umns in the table. 

[0070] In another embodiment of the invention load 
balancing is taken into account atthe selection of serv- 
ice suppliers. This can be performed for example after 
the selection of service suppliers for the set of service 
suppliers, and during the selection of service suppliers 
for each client. 

[0071] In an embodiment of the invention, a new, ad- 
ditional client requesting the service is served by a new, 
additional service supplier. 

[0072] In another embodiment of the invention a new, 
additional client requesting the service is served by one 
of the existing service suppliers. 
[0073] In a preferred embodiment of the invention, the 
service supplier is selected which is the closest one to 
the new additional client. 

[0074] In another embodiment of the invention, the 
method is executed again when a new additional client 
requests the service. 

[0075] In a further embodiment of the invention, the 
method is performed by a computer program or a soft- 
ware module. 

[0076] The invention further relates to a computer pro- 
gram, stored on a computer readable medium or loaded 
into a memory of a computer, adapted to performing a 
method according to any of the claims 1 to 11 . A com- 
puter readable medium is any means that stores infor- 
mation and can be read by an input device of a compu- 
ter, for example a floppy disc, a hard disc, or an optical 
disc. 
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Claims 

1 . Method for determining a distribution of a service in 
a network (NW1) comprising a plurality of service 
suppliers (S1 , S2, S3 f S4, S5, S6, S7, S8, S9, S10, 
S1 1 , S12, S13, S14, S15, S16, S17, S1 8, S1 9, S20, 
S21, S22, S23) and a plurality of clients (C1, C2, 
C3, C4, C5, C6 P C7), the service having require- 
ments regarding a communication between a serv- 
ice supplier and a client and requirements on the 
characteristics of a service supplier and of a client, 
the method comprising the steps of: 

determining the requirements of the service, 
determining the characteristics of service sup- 
pliers and clients 

determining for each client the service suppli- 
ers that fulfil the requirements of the service, 
determining a set of service suppliers that can 
supply the service to the plurality of clients, and 
selecting for each client a service supplier out 
of the set of service suppliers. 

2. Method according to claim 1 , with the additional 
step of generating a service distribution tree (SDT1 ) 
that represents a hierarchical structure of service 
suppliers. 

3. Method according to any of the preceding claims 
with the additional step of determining a simplified 
distribution tree (SSDT1 ) by removing service sup- 
pliers from branches of the distribution tree that can- 
not supply at least two clients and wherein the set 
of service suppliers is determined by using the sim- 
plified distribution tree. 



determining a central update unit, 
determining the maximum delay permitted for 
update purposes, 

determining delays between service suppliers 
5 and the central update unit, 



that are performed before the determining of the set 
of service suppliers, wherein no service supplier 
with a delay higher than the permitted maximum de- 
10 lay is selected for the set of service suppliers. 

8. Method according to any of the preceding claims 
wherein it is distinguished between an uplink, from 
client to service supplier and a downlink, from serv- 
es ice supplier to client, communication in a way that 

different service suppliers communicate in the up- 
. link and the downlink commu nlcation with the client. 

9. Method according to any of the preceding claims, 
20 wherein the downlink connection is implemented as 

a streaming of data. 

10. Method according to any of the preceding claims, 
wherein on a downlink connection only update in- 

25 formation is transmitted. 

11. Method according to any of the preceding claims, 
wherein a service supplier is one of a sub-network, 
a server or a proxy server. 

30 

12. Computer program, stored on a computer readable 
medium or in a form that can be loaded into the 
memory of a computer, adapted to perform a meth- 
od according to any of the claims 1 to 11 . 

35 



4. Method according to any of the preceding claims, 
wherein the distribution of a service is performed by 
at least one of a migration, a replication or a parti- 
tioning of a service. 40 



5. Method according to any of the preceding claims, 
wherein the determining of the set of service sup- 
pliers is performed according to a predefined policy. 

45 

6. Method according to any of the preceding claims 
with the additional steps of: 

determining the maximum delay permitted 
among service suppliers, so 
determining delays among service suppliers, 

that are performed before the determining of the set 
of service suppliers. 

55 

7. Method according the preceding claim with the ad- 
ditional steps of : 
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